<template>
    <div class="app-container">
        <el-card shadow="never">
            <!-- 条件查询 -->
            <el-form v-show="showSearch" ref="queryForm" :model="queryParams" label-width="120px" @keyup.enter.native="submitSearch" @submit.native.prevent>
                <el-row>
                    <el-col :md="6" :sm="12" v-if="!queryObj.tenant_id">
                        <el-form-item label="租户:" prop="tenant_id.value">
                            <SelectPage v-model="queryParams.tenant_id.value" :url="'/admin/ch.tenant/selectPage'" show_field="name"
                                        placeholder="请选择租户"
                                        show_id='id' query_field="id" :multiple="false" />
                        </el-form-item>
                    </el-col>
                    <el-col :md="queryObj.tenant_id ? 12 : 6" :sm="12">
                        <el-form-item label="用户昵称:" prop="user_id.value">
                            <SelectPage v-model="queryParams.user_id.value" :url="'/admin/user/selectPage'" placeholder="请选择用户昵称"
                                        show_field="nickname" show_id='uid'  query_field="uid" :multiple="false" />
                        </el-form-item>
                    </el-col>
                    <el-col :md="6" :sm="12">
                        <el-form-item class="ele-text-right" label-width="50px">
                            <el-button type="primary" size="mini" @click="submitSearch" icon="el-icon-search" class="ele-btn-icon">搜索 </el-button>
                            <el-button @click="resetQuery" size="mini" icon="el-icon-refresh">重置</el-button>

                        </el-form-item>
                    </el-col>
                </el-row>
            </el-form>
            <el-row :gutter="10" class="mb8">
                <el-col :span="1.5">
                    <el-button type="primary" plain icon="el-icon-plus" size="mini" @click="open" v-hasPermi="api.add">添加</el-button>
                </el-col>
                <el-col :span="1.5">
                    <el-button type="danger" plain icon="el-icon-delete" size="mini" :disabled="multiple" @click="handleDelete" v-hasPermi="api.delete">删除</el-button>
                </el-col>
                <el-col :span="1.5">
                    <el-button type="warning" plain icon="el-icon-download" size="mini" v-loading="exportLoading" @click="handleExport" v-hasPermi="api.export">导出</el-button>
                </el-col>
                <right-toolbar :showSearch.sync="showSearch" @queryTable="initIndex" :columns="columns" printId="#quickadmin"></right-toolbar>
            </el-row>

            <!-- 列表 -->
            <qa-table
                :source="tableData"
                :columns="columns"
                :selection="false"
                :loading="loading"
                @sortChange="sortChange"
                @statusChange="statusChange"
                @selectionChange="selectionChange"
                id="quickadmin"
            >
                <template v-slot:action>
                    <el-table-column label="操作" width="120" fixed="right">
                        <template slot-scope="scope">
                            <el-button size="mini" type="text" icon="el-icon-edit" @click="handleEdit(scope.row)" v-hasPermi="api.edit">编辑</el-button>
<!--                            <el-button size="mini" type="text" icon="el-icon-tickets" @click="handleDetail(scope.row)" v-hasPermi="api.find">详情</el-button>-->
                            <el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)" v-hasPermi="api.delete">删除</el-button>
                        </template>
                    </el-table-column>
                </template>
            </qa-table>

            <!-- 分页 -->
            <pagination :total="total" :page.sync="pageInfo.page" :limit.sync="pageInfo.limit" @pagination="initIndex" />
        </el-card>
        <!-- 编辑弹窗 -->
       <el-dialog  :append-to-body='true'  :title="!disabled ? '编辑' : '详情'" :visible="editOpen" :before-close="beforeClose" destroy-on-close>
            <EditForm ref="editForm" :findFormData="findFormData" :disabled="disabled" @submitForm="submitForm" :editFormParams="editFormParams" @editFormCancel="beforeClose" />
        </el-dialog>
    </div>
</template>

<script>
import { curdMixin } from '@/mixins/curdMixin'
import EditForm from './EditFormCom'

export default {
    name: 'Curd',
    mixins: [curdMixin],
    components: { EditForm },
  props: {
      queryObj: {
        type: Object,
        default: ()=> {}
      }
  },
    data() {
        return {
            // table结构
            columns: [
                {
                    visible: true,
                    label: '编辑',
                    prop: 'id',
                    width: 60
                },
                {
                    visible: true,
                    label: '所属用户',
                    prop: 'myUser.nickname',
                    formatter: (prop, row) => {
                        return  row.myUser.nickname_text
                    },
                },
                {
                    visible: true,
                    label: '用户名',
                    prop: 'username',
                    width: 120,
                    overflow: true
                },
                {
                    visible: true,
                    label: '联系手机号',
                    prop: 'phone',
                    width: 120,
                    overflow: true
                },
                {
                    visible: true,
                    label: '头像',
                    prop: 'head_image',
                    component:'QuickAdminImage',
                },
                {
                    visible: true,
                    label: '电子邮箱',
                    prop: 'email',
                  width: 100
                },
                {
                    visible: true,
                    label: '状态 ',
                    prop: 'status',
                    formatter: (prop, row) => {
                        return  row.status_text
                    },
                },
                {
                    visible: true,
                    label: '创建时间',
                    prop: 'create_time',
                    width: 120,
                    overflow: true
                },
                {
                    visible: true,
                    label: '更新时间',
                    prop: 'update_time',
                    width: 120,
                    overflow: true
                }
            ],
            // 接口地址
            api: {
                index: `/admin/ch.admin/index`,
                find: `/admin/ch.admin/find`,
                add: `/admin/ch.admin/add`,
                edit: `/admin/ch.admin/edit`,
                delete: `/admin/ch.admin/delete`,
                export: `/admin/ch.admin/export`,
                status: `/admin/ch.admin/status`
            },
            editFormParams: {},
            // 搜索表单是否展开
            searchExpand: false,
            // 查询参数
            queryParams: {
                tenant_id: { value: undefined, op: '='},
                user_id: { value: undefined, op: '='},
            },
          tableIsJoinLoad: false
        }
    },
  mounted() {
      if (this.queryObj.tenant_id) {
        this.queryParams.tenant_id.value = this.queryObj.tenant_id
        this.columns[1].visible = false
      }else{
        this.columns.splice(1, 0, {
          visible: true,
          label: '租户',
          prop: 'tenant.name',
          formatter: (prop, row) => {
            return  row.tenant.name_text
          },
        },)
      }
    this.initIndex()
  }
}
</script>
